<template>
  <div>
    <van-nav-bar title="黑马头条" />

    <van-form @submit="onSubmit">
      <van-field
        v-model="formLogin.mobile"
        type="tel"
        name="手机号"
        label="手机号"
        placeholder="请输入手机号"
        required
        :rules="[{ required: true, message: '请正确填写手机号', pattern:/^1[3-9]\d{9}$/,trigger:'onChange' }]"
      />
      <van-field
        v-model="formLogin.code"
        type="password"
        name="密码"
        label="密码"
        placeholder="请输入密码"
        required
        :rules="[{ required: true, message: '请填写6位正确密码',pattern:/^\d{6}$/,trigger:'onChange' }]"
      />
      <div style="margin: 16px">
        <van-button round block type="info" native-type="submit" :disabled='isLogin' :loading='isLogin' loading-text='登入中.......'
          >登入</van-button
        >
      </div>
    </van-form>
  </div>
</template>

<script>
import { mapActions } from 'vuex'
import { Notify } from 'vant'
export default {
  name: 'Login',
  data () {
    return {
      formLogin: {
        mobile: 15888888888,
        code: 246810
      },
      isLogin: false
    }
  },
  methods: {
    // 辅助函数固定写法
    ...mapActions(['asyncLoginAction']),
    async  onSubmit (values) {
      // console.log('submit', values)
      // 调用接口的步骤
      // 1 引入接口
      // 2 在方法中调用接口
      // 3 调用接口时如果需要传参 需要将参数整理传入保证参数的数据类型和数据格式
      // 4 定义变量接收返回值
      this.isLogin = true
      try {
        await this.asyncLoginAction(this.formLogin)
        this.isLogin = false
        Notify({ type: 'success', message: '登入成功' })
        // replace 是不能回退的 相当于路由的重置   push是有路由的历史记录的
        this.$router.replace({ path: '/layout' })
      } catch (error) {
        this.isLogin = false
        Notify({ type: 'danger', message: '登入失败' })
      }
    }
  }
}
</script>

<style lang="less" scoped>
// 如果组件直接引入并且组件上带有class可以直接使用这个class改变组件样式
// .van-nav-bar{
// background-color: #007bff;
// }

// 如果我想改变引入组件的里面的dom上的样式直接使用class是不生效的
// 原因因为组件上使用了scoped他在打包过程中会给dom添加个类用作样式
// 可以通过在类名前面加上/deep/实现类名穿透改变子组件的样式

// 预处理器不同使用的穿透符也有所不同  scss ::deep    stylus  >>>
// /deep/ .van-nav-bar__title{
// color: white;
// }
</style>
